package simple;

/**
 * 给定一个数组 nums，编写一个函数将所有 0 移动到数组的末尾，同时保持非零元素的相对顺序。
 * <p>
 * 请注意 ，必须在不复制数组的情况下原地对数组进行操作
 *
 * @link https://leetcode-cn.com/problems/move-zeroes/
 */
public class MoveZeroes {
    class Solution {
        public void moveZeroes(int[] nums) {
            int l = 0;
            int r = 0;
            while (r < nums.length) {
                if (nums[r] != 0) {
                    int t = nums[l];
                    nums[l] = nums[r];
                    nums[r] = t;
                    l++;
                }
                r++;
            }
        }
    }
}
